A few quick hints about building and debugging AWNP applications.
Before writing an AWNP GUI application prototype the GUI with a simple text file (mygui). Use
'copy mygui awnpipe:pipename/xcwcon:'
This speeds up testing of layout changes! Also note you can comment out lines in your file by starting them with ';'. Any line with a semicolon in the first position is ignored.
--
NAME YOUR PIPES !
Rather than opening 'awnpipe:/xc' provide a unique name. Use 'awnpipe:PipeName/xc'.
A common problem when developing an AWNP application is to find the pipe conversation hangs. Usually this means your program is trying to read data from the pipe, and the pipe is trying to read data from your application. (a read is pending on both ends of the pipe).
This can be cleared by issuing a simple shell command.
'echo >awnpipe:PipeName/a'
Both reads are aborted and AWNP usually notices a problem and exits cleanly.
--
Some times it will be useful to trace the conversation your program has with AWNP. Again this can be done with a simple shell command.
'type awnpipe:PipeName/t/i'
All data passing either way through the pipe will be output. When your program exits the type command will return. ( this is not limited to to GUI applications. It works for ALL awnp connections!)
You can also use
'copy awnpipe:PipeName/t/i mylogfile'
This saves the conversation to the logfile of course.
You can use both at the same time, in fact you can 'twin' the data stream as many times as you like.
Some times durring testing you might create a GUI with no close gadget, you can usualy close ANY GUI with 'control backslash' like you can with a con:.
--
In general you can not assume that you can modify all the parameters you can define for objects. Also in some cases the parameter names or usage may be different in the modify command when compared to the definition line.